Filename | (eval 1108)[/usr/share/perl5/Sub/Quote.pm:5] |
Statements | Executed 9011 statements in 23.0ms |
Eval Invoked At | /usr/share/perl5/Sub/Quote.pm line 5 |
Sibling evals | 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14 |
Calls | P | F | Exclusive Time |
Inclusive Time |
Subroutine |
---|---|---|---|---|---|
6001 | 3 | 3 | 131ms | 7.78s | select_single | DBIx::Class::Storage::DBI::
1 | 1 | 1 | 18µs | 36µs | BEGIN@5 | Sub::Quote::
1 | 1 | 1 | 9µs | 9µs | BEGIN@11.2971 | DBIx::Class::Storage::DBI::
Line | State ments |
Time on line |
Calls | Time in subs |
Code |
---|---|---|---|---|---|
1 | { | ||||
2 | 2 | 2µs | my $orig = ${$_[1]->{"\$orig"}}; | ||
3 | 1 | 300ns | my $_UNQUOTED = ${$_[1]->{"\$_UNQUOTED"}}; | ||
4 | 1 | 300ns | my $_QUOTED = ${$_[1]->{"\$_QUOTED"}}; | ||
5 | 2 | 141µs | 2 | 53µs | # spent 36µs (18+17) within Sub::Quote::BEGIN@5 which was called:
# once (18µs+17µs) by Sub::Quote::_clean_eval at line 5 # spent 36µs making 1 call to Sub::Quote::BEGIN@5
# spent 17µs making 1 call to warnings::unimport |
6 | # spent 7.78s (131ms+7.65) within DBIx::Class::Storage::DBI::select_single which was called 6001 times, avg 1.30ms/call:
# 3000 times (116ms+7.65s) by DBIx::Class::ResultSet::single at line 46, avg 2.59ms/call
# 3000 times (15.0ms+621µs) by DBIx::Class::ResultSet::single at line 1099 of DBIx/Class/ResultSet.pm, avg 5µs/call
# once (24µs+0s) by DBIx::Class::ResultSet::single at line 56 of Sub/Defer.pm | ||||
7 | $_QUOTED if 0; | ||||
8 | 3000 | 566µs | $_UNQUOTED if 0; | ||
9 | # BEGIN quote_sub PRELUDE | ||||
10 | package DBIx::Class::Storage::DBI; | ||||
11 | # spent 9µs within DBIx::Class::Storage::DBI::BEGIN@11.2971 which was called:
# once (9µs+0s) by Sub::Quote::_clean_eval at line 16 | ||||
12 | 1 | 2µs | $^H = "133090"; | ||
13 | 1 | 400ns | ${^WARNING_BITS} = "UUUUUUUUUUUUUUUUU"; | ||
14 | 1 | 6µs | %^H = ( | ||
15 | ); | ||||
16 | 1 | 164µs | 1 | 9µs | } # spent 9µs making 1 call to DBIx::Class::Storage::DBI::BEGIN@11.2971 |
17 | # END quote_sub PRELUDE | ||||
18 | |||||
19 | 3000 | 5.52ms | if ( | ||
20 | # only fire when invoked on an instance, a valid class-based invocation | ||||
21 | # would e.g. be setting a default for an inherited accessor | ||||
22 | ref $_[0] | ||||
23 | and | ||||
24 | ! $_[0]->{_driver_determined} | ||||
25 | and | ||||
26 | ! $_[0]->{_in_determine_driver} | ||||
27 | and | ||||
28 | # if this is a known *setter* - just set it, no need to connect | ||||
29 | # and determine the driver | ||||
30 | ( 1 or @_ <= 1 ) | ||||
31 | and | ||||
32 | # Only try to determine stuff if we have *something* that either is or can | ||||
33 | # provide a DSN. Allows for bare $schema's generated with a plain ->connect() | ||||
34 | # to still be marginally useful | ||||
35 | $_[0]->_dbi_connect_info->[0] | ||||
36 | ) { | ||||
37 | $_[0]->_determine_driver; | ||||
38 | |||||
39 | # work around http://rt.perl.org/rt3/Public/Bug/Display.html?id=35878 | ||||
40 | goto $_[0]->can("select_single") unless DBIx::Class::_ENV_::BROKEN_GOTO; | ||||
41 | |||||
42 | my $cref = $_[0]->can("select_single"); | ||||
43 | goto $cref; | ||||
44 | } | ||||
45 | |||||
46 | 3000 | 16.6ms | 3000 | 7.77s | goto $orig; # spent 7.77s making 3000 calls to DBIx::Class::Storage::DBI::select_single, avg 2.59ms/call |
47 | } | ||||
48 | 1 | 1µs | $$_UNQUOTED = \&DBIx::Class::Storage::DBI::select_single | ||
49 | } | ||||
50 | 1 | 4µs | 1; | ||
51 | |||||
52 | ; |